| Total Complexity | 5 |
| Total Lines | 39 |
| Duplicated Lines | 0 % |
| Changes | 0 | ||
| 1 | import ResponseInterceptor from './response-interceptor' |
||
| 3 | |||
| 4 | /** |
||
| 5 | * If access token is not valid try to renew authentication |
||
| 6 | * and retry the previous call. |
||
| 7 | */ |
||
| 8 | export default class RefreshAuthInterceptor extends ResponseInterceptor { |
||
| 9 | |||
| 10 | /** |
||
| 11 | * If the error is 401 for token expired try to renew tokens re-send the original request. |
||
| 12 | * |
||
| 13 | * @param error The original error. |
||
| 14 | */ |
||
| 15 | public async errorHandler(error: any): Promise<any> { |
||
| 16 | if (!error.response || !this.isTokenExpired(error.response)) { |
||
| 17 | // Not an expired token's fault. |
||
| 18 | if (error.response?.status === 401) { // if 401 clear tokens |
||
| 19 | const storage = this.beditaClient.getStorageService(); |
||
| 20 | await storage.clearTokens(); |
||
| 21 | await storage.remove('user'); |
||
| 22 | } |
||
| 23 | |||
| 24 | return Promise.reject(error); |
||
| 25 | } |
||
| 26 | |||
| 27 | await this.beditaClient.renewTokens(); |
||
| 28 | delete error.config.headers.Authorization; |
||
| 29 | |||
| 30 | return await this.beditaClient.request(error.config); |
||
| 31 | } |
||
| 32 | |||
| 33 | /** |
||
| 34 | * Return `true` if it's a token expired response error. |
||
| 35 | * |
||
| 36 | * @param response The response |
||
| 37 | */ |
||
| 38 | protected isTokenExpired(response: AxiosResponse): boolean { |
||
| 39 | const code = response.data && response.data.error && response.data.error.code; |
||
| 40 | |||
| 41 | return response.status === 401 && code === 'be_token_expired'; |
||
| 42 | } |
||
| 44 |